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AMENDMENTS TO THE CLAIMS 



This listing of claims will replace all prior versions and listings of claims in the application. 
Listing of Claims: 
Claim 1 (Canceled), 

Claim 2 (Previously Presented): A system for encoding one or more repetitive data blocks in 

data communicated over a network comprising: 

an encoder module, coupled in the network, the encoder module intercepting data 
communicated from a server to a client device, the encoder module extracting data 
blocks from different communication sessions from the intercepted data, each 
extracted block having a destination address of the client device, the encoder module 
determining whether the client device is supported for decoding by at least one 
corresponding decoder module based on the destination address of the client device, 
and the encoder module passing through the data when the destination address of the 



a memory, accessible to the encoder module, for storing the contents of one or more data 
blocks previously transmitted by the encoder module wherein the encoder module 
determines whether there is a match between the contents of each of the extracted 
data blocks and the contents of at least one previously transmitted data block, 

wherein the memory comprises a least recently used data structure for storing one or more 
previously transmitted unique data blocks, said least recently used data structure 
having a maximum capacity and each of the previously transmitted unique data blocks 
having a unique identifier and a position in an order of most recently used to least 
recently used-ofthe one ot more stored blocks, 

wherein responsive to said match, the encoder module encodes the respective extracted 
data block, transmits the respective extracted data block in encoded form to the at 
least one corresponding decoder module and associates the previously transmitted 



client device is not supported for decoding by a decoder module; and 
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data block having the matching contents with the position in the least recently used 
data structure indicating the most recently used previously transmitted data block, and 
wherein responsive to no match, the encoder module transmits the respective extracted 
data block in intercepted form to the at least one corresponding decoder module. 

Claim 3 (Previously Presented): The system of claim 2 wherein the encoded form of the 
respective extracted data block is transparent to one or more nodes in the network. 

Claim 4 (Previously Presented): The system of claim 2 wherein the encoder module is coupled 
via a switch in a physical connection between two nodes of the network, responsive to a first 
configuration of the switch, the encoder module processing data that traverse the physical 
connection between these two nodes, and responsive to a second configuration of the switch, the 
data bypassing the encoder module. 

Claim 5 (Previously Presented): The system of claim 2 wherein the encoder module operates in a 
node in the network and decides a route for the respective extracted data block to the at least one 
corresponding decoder module supporting its destination address. 

Claim <5 (Previously Presented): The system of claim 2 wherein the encoder module, responsive 
to a match in contents, transmits an indicator, identifying that the contents of a respective data 
block have been previously transmitted. 

Claim 7 (Previously Presented): The system of claim 6 wherein the indicator is a special symbol. 

Claim 8 (Previously Presented): The system of claim 6 wherein the indicator is an extra header. 

Claim 9 (Previously Presented): The system of claim 2 wherein at least one respective data block 
is a packet pay load. 
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Claim 10 (Previously Presented): The system of claim 2 wherein at least one respective data 
block is a portion of a packet payload. 

Claim 1 1 (Previously Presented): The system of claim 2 wherein the encoder module encodes at 
least one extracted data block using a synchronization mechanism for verifying the identification 
of the one or more previously transmitted data blocks with the at least one corresponding decoder 
module supporting the destination address of the extracted data block. 

Claim 12 (Previously Presented): The system of claim 11 wherein the synchronization 
mechanism is an explicit synchronization mechanism. 

Claim 13 (Previously Presented): The system of claim 1 1 wherein the synchronization 
mechanism is an implicit synchronization mechanism. 

Claim 14 (Previously Presented): The system of claim 1 1 wherein the implicit synchronization 
mechanism is a reliable network transport protocol. 

Claim 15 (Previously Presented): The system of claim 2 further comprising the encoder module, 
responsive to no match between the contents of the respective extracted data block and the 
contents of at least one of the previously transmitted blocks, determining whether to delete at 
least one of the previously transmitted data blocks in the memory, and storing the respective 
extracted data block in intercepted form in the memory. 

Claim 16 (Cancelled). 

Claim 17 (Cancelled). 
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Claim 1 8 (Previously Presented): A system for encoding one or more repetitive data blocks in 

data communicated over a network comprising: 

an encoder module, coupled in the network, the encoder module intercepting data 
communicated from at least one server to at least one client device, the encoder 
module extracting data blocks from different communication sessions from the 
intercepted data, each extracted block having a destination address of the client device 
to which the extracted data block is destined, the encoder module determining 
whether the client device is supported for decoding by at least one corresponding 
decoder module based on the destination address of the client device, and the encoder 
module passing through data when the destination address of the client device is not 
supported for decoding by a decoder module; and 
a memory, accessible to the encoder module, having a least recently used data structure 
for storing the contents of one or moTe unique data blocks previously transmitted by 
the encoder module, said least recently used data structure having a maximum 
capacity and each of the previously transmitted unique data blocks having a unique 
identifier and a position in an order of most recently used to least recently used of the 
one or more stored blocks, 
wherein the encoder module determines whether there is a match between the contents of 
each of the extracted data blocks and the contents of at least one previously 
transmitted data block, 
wherein responsive to said match, the encoder module encodes the respective extracted 

data block and transmits the respective extracted data block in encoded form to the at least one 

corresponding decoder module, and 

wherein responsive to no match, the encoder module transmits the respective extracted 

data block in intercepted form to the at least one corresponding decoder module, stores the 

extracted data block in the least recently used data structure, and associates the position of most 

recently used with the extracted data block. 
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Claim 19 (Previously Presented): The system of claim 18 

wherein, responsive to the least recently used data structure being at the maximum 

capacity, the encoder module deletes the previously transmitted data block having the 
order position of the least recently used data block. 

Claim 20 (Previously Presented): A system for encoding one or more repetitive data blocks in 
data communicated over a network comprising: 

an encoder module, coupled in the network, the encoder module intercepting the data, the 

encoder module extracting data blocks from different communication sessions from 

the intercepted data; 

a memory, accessible to the encoder module, having a least recently used data structure 
for storing the contents of one or more unique data blocks previously transmitted by 
the encoder module, said least recently used data structure having a maximum 
capacity and each of the previously transmitted unique data blocks having a unique 
identifier and a position in an order of most recently used to least recently used of the 
one or more stored blocks, 

wherein, responsive to the least recently used data structure being at the maximum 

capacity, the encoder module deletes the previously transmitted data block having the 
order position of the least recently used data block, 

wherein the encoder module determines whether there is a match between the contents of 
each of the extracted data blocks and the contents of at least one previously 
transmitted data block, 

wherein responsive to said match, the encoder module encodes the respective extracted 
data block and transmits the respective extracted data block in encoded form to at 
least one corresponding decoder module, and 

wheiein responsive to no match, the encoder module transmits the respective extracted 
data block in intercepted form to the at least one corresponding decoder module, 
stores the extracted data block in the least recently used data structure, and associates 
the position of most recently used with the extracted data block; and 
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a synchronization mechanism including a same size for the least recently used data 
Structure as the size of a second least recently used data structure accessible by the 
corresponding decoder module receiving the respective extracted data block, and a 
reliable network transport protocol being used for the transmission of the respective 
extracted data block. 



Claim 21 (Previously Presented): A system for encoding one or more repetitive data blocks in 
data communicated over a network comprising; 

an encoder module, coupled in the network, the encoder module intercepting the data, the 

encoder module extracting data blocks from different communication sessions from 

the intercepted data; 

a memory, accessible to the encoder module, having a least recently used data structure 
for storing the contents of one or more unique data blocks previously transmitted by 
the encoder module, said least recently used data structure having a maximum 
capacity and each of the previously transmitted unique data blocks having a unique 
identifier and a position in an order of most recently used to least recently used of the 
one or more stored blocks, 

wherein, responsive to the least recently used data structure being at the maximum 

capacity, the encoder module deletes the previously transmitted data block having the 
order position of the least recently used data block, 

wherein the encoder module determines whether there is a match between the contents of 
each of the extracted data blocks and the contents of at least one previously 
transmitted data block, 

wherein responsive to said match, the encoder module encodes the respective extracted 
data block and transmits the respective extracted data block in encoded form to at 
least one corresponding decoder module, and 

wherein responsive to no match, the encoder module transmits the respective extracted 
data block in intercepted form to the at least one corresponding decoder module, 
stores the extracted data block in the least recently used data structure, and associates 
the position of most recently used with the extracted data block; and 
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a synchronization mechanism including an indicator for each transmitted extracted data 
block indicating whether the data block has been associated with the least recently 
used data structure and an installed flag associated with each of the previously 
transmitted data blocks in the least recently used data structure, the installed flag 
indicating whether the associated data block has been stored in a second least recently 
used data structure accessible by the corresponding decoder module that has received 
the respective extracted data block. 

Claim 22 (Previously Presented): The system of claim 21 wherein the installed flag is updated 
after a fixed amount of time after transmission of the data block. 

Claim 23 (Previously Presented): The system of claim 21 wherein the installed flag is updated 
responsive to a notification from the corresponding decoder module that the associated data 
block has been stored in the second least recently used data structure. 

Claim 24 (Previously Presented): The system of claim 2 wherein the memory stores a data 
structure for associating a signature with one or more of the previously transmitted data blocks, 
and wherein the encoder module computes a signature for the respective extracted data block, 
compares the computed signature with at least one signature associated with the one or more 
previously transmitted data blocks, and responsive to a match in signature, selecting the one or 
more previously transmitted data blocks having the match in signature for content comparison 
with the respective extracted data block. 

Claim 25 (Previously Presented); The system of claim 24 wherein the data structure for 
associating a signature with one or m ore of the previously transmitted data blocks is a hash table 
having one or more bins. 
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Claim 26 (Previously Presented): A system for encoding one or more repetitive data blocks in 
data communicated over a network comprising: 

an encoder module intercepting the data and extracting data blocks from different 
communication sessions from the intercepted data, each extracted block having a 
destination address of a client device to which the extracted data block is destined and 
that is supported for decoding by at least one corresponding decoder module, and the 
encoder module passing through data not having a supported destination address; 

a memory, accessible to the encoder module, for storing the contents of one or more data 
blocks previously transmitted by the encoder module; and 

a hash table having one or more bins for associating a signature with one or more of the 
previously transmitted data blocks, 

wherein the encoder module determines whether there is a match between the contents of 
each of the extracted data blocks and the contents of at least one previously 
transmitted data block by computing a signature for the respective extracted data 
block and comparing the computed signature with at least one signature associated 
with the one or more previously transmitted data blocks, the computed signature value 
being less than the number of hash table bins, 

wherein, responsive to a match in signature, the encoder selects the one or more 
previously transmitted data blocks having the match in signature for content 
comparison with the respective extracted data block* encodes the respective extracted 
data block and transmits the respective extracted data block in encoded form to the at 
least one corresponding decoder module> and 

wherein, responsive to no match, the encoder module transmits the respective extracted 
data block in intercepted form to the at least one corresponding decoder module. 
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Claim 27 (Previously Presented): A system for encoding one or more repetitive data blocks in 
data communicated over a network comprising: 

an encoder module intercepting the data and extracting data blocks from different 
communication sessions from the intercepted data, each extracted block having a 
destination address of a client device to which the extracted data block is destined and 
that is supported for decoding by at least one corresponding decoder module, and the 
encoder module passing through data not having a supported destination address; 

a memory, accessible to the encoder module, for storing the contents of one or more data 
blocks previously transmitted by the encoder module; and 

a hash table having one or more bins for associating a signature with one or more of the 
previously transmitted data blocks, 

wherein the encoder module determines whether there is a match between the contents of 
each of the extracted data blocks and the contents of at Jeast one previously 
transmitted data block by computing a signature for the respective extracted data 
block and comparing the computed signature with at least one signature associated 
with the one or more previously transmitted data blocks, the computed signature value 
being computed as a modulo of the number of bins, 

wherein, responsive to a match in signature, the encoder selects the one or more 
previously transmitted data blocks having the match in signature for content 
comparison with the respective extracted data block, encodes the respective extracted 
data block and transmits the respective extracted data block in encoded form to the at 
least one corresponding decoder module, and 

wherein, responsive to no match, the encoder module transmits the respective extracted 
data block in intercepted form to the at least one corresponding decoder module. 

Claim 28 (Previously Presented): The system of claim 2 further comprising an encapsulation 
module for encapsulating the extracted data blocks for transport over the network. 

Claim 29 (Previously Presented): The system of claim 28 wherein at least one of the extracted 
data blocks is included in a packet, and the packet is encapsulated as one packet. 
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Claim 30 (Previously Presented): The system of claim 28 wherein at least one of the extracted 
data blocks is included in a packet and the packet is encapsulated with at least one other packet in 
an outgoing packet for transmission. 

Claim 31 (Previously Presented): The system of claim 28 wherein the encapsulation of at least 
one of the extracted data blocks is transparent to one or more nodes in the network. 

Claim 32 (Previously Presented): The system of claim 28 wherein the encapsulation module 
comprises a timer mechanism for ensuring that the at least one extracted data block is held in a 
buffer coupled to the encapsulation module for no more than a pre-determined maximum time 
before being transmitted, 

Claim 33 (Previously Presented): The system of claim 30 wherein the encapsulation module 
comprises a timer mechanism for ensuring that the at least one extracted data block is held in a 
buffer coupled to the encapsulation module for no more than a pre-determined maximum time 
before being transmitted. 

Claim 34 (Previously Presented): The system of claim 28 wherein the encoder module encodes 
at least one data block at a first layer of a model describing the flow of data across a network and 
the encapsulation module encapsulates the at least one extracted data block at a second layer of 
the model 

Claim 35 (Previously Presented): The system of claim 34 wherein the first and second layers are 
at the same layer of the model. 

Claim 36 (Previously Presented): The system of claim 35 wherein one of the layers is a 
connection-oriented layer and the other layer is a connectionless layer. 
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Claim 37 (Previously Presented): A system for encoding one or more repetitive data blocks in 
data communicated over a network comprising: 

an encoder module intercepting data communicated from a server to a client device and 
extracting data blocks from different communication sessions from the intercepted 
data, each extracted block having a destination address of the client device, the 
encoder module determining whether the client device is supported for decoding by at 
least one corresponding decoder module based on the destination address of the client 
device, and the encoder module passing through the data when the destination address 
of the client device is not supported for decoding by a decoder module; and 

a memory, accessible to the encoder module, for storing the contents of one or more data 
blocks previously transmitted by the encoder module, 

wherein the encoder module determines whether there is a match between the contents of 
each of the extracted data blocks and the contents of at least one previously 
transmitted data block, 

wherein responsive to said match, the encoder module encodes the respective extracted 
data block and transmits the respective extracted data block in encoded form to the at 
least one corresponding decoder module, 

wherein responsive to no match, the encoder module transmits the respective extracted 
data block in intercepted form to the at least one corresponding decoder module, and 

wherein the encoder module receives routing information in accordance with a routing 
protocol over the network from each of one or more corresponding decoder modules 
with which it communicates and determines the one or more addresses supported by 
each respective decoder module from the routing information, wherein the routing 
information includes network topology information for the network. 

Claim 38 (Previously Presented): The system of claim 37 wherein the encoder module 
determines the network topology information based upon the routing information from the one or 
more decoder modules. 
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Claim 39 (Previously Presented): The system of claim 38 wherein, responsi ve to multiple 
decoder modules in the network supporting the same address, the encoder module determines a 
destination decoder module for one or more extracted data blocks based upon network topology 
information and routing criteria. 

Claim 40 (Previously Presented): The system of claim 38 wherein the routing criteria includes 
routing cost. 

Claim 4 1 (Previously Presented): The system of claim. 38 wherein the routing criteria includes 
routing distance. 

Claim 42 (Currently Amended): A system for decoding one or more repetitive data blocks in 

data communicated over a network comprising: 

a decoder module being coupled in the network, the decoder module transmitting routing 
information over the network to a corresponding encoder module in accordance with 
a routing protocol, the routing information including network topology information 
for the network and identifying one ot more addresses of client devices that the 
decoder module supports to control selective encoding of data at the encoder module 
based on the client devices supported bv the decoder module bv determining with the 
encoder module whether client devices are supported for decoding by at least one 
corresponding decoder module based on destination addresses of the client devices 
and passing through the data when the destination addresses of the cl ient devices are 
not supported for decoding bv a decoder module, the decoder module receiving data 
blocks for different communication sessions from the corresponding encoder module, 
each of the data blocks having a destination address of a client device to which the 
extracted data block is destined; and 
a memory accessible to the decoder module for storing the contents of one or more data 
blocks previously received from the corresponding encoder module wherein the 
decoder module determines whether the contents of each of the received data blocks 
is in encoded form, 
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wherein the memory stores the previously received data blocks in a least recently used 
data structure for storing one or more previously received unique data blocks, the least 
recently used data structure having a maximum capacity and each of the previously 
received unique data blocks having a unique identifier and a position in an order of 
most recently used to least recently used of the one or more previously received 
blocks, 

wherein responsive to the respective data block being in encoded form, the decoder 
module selects the contents of a matching previously received block as the contents 
for the respective encoded block and associates the previously received data block 
having the matching contents with the position in the least recently used data structure 
. indicating the most recently used previously received data, and 

wherein responsive to the data block being unencoded, the decoder module stores the 
contents of the respective received data block as a previously received data block. 

Claim 43 (Previously Presented): The system of claim 42 wherein the decoder module is 
coupled via a switch in a physical connection between two nodes of the network, responsive to a 
first configuration of the switch, the encoder module processing data that traverse the physical 
connection between these two nodes, and responsive to a second configuration of the switch, the 
data bypassing the decoder module. 

Claim 44 (Previously Presented): The system of claim 42 wherein the decoder module operates 
in a node in the network and decides a route for a decoded data block to its destination address. 

Claim 45 (Previously Presented): The system of claim 42 wherein the decoder module receives 
an indicator for identifying that the contents of at least one encoded data block have been 
previously transmitted to the decoder module. 

Claim 46 (Previously Presented): The system of claim 45 wherein the indicator is a special 
symbol 
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Claim 47 (Previously Presented): The system of claim 45 wherein the indicator is an extra 
header. 

Claim 48 (Previously Presented): The system of claim 42 wherein at least one encoded data 
block is a packet payload. 

Claim 49 (Previously Presented): The system of claim 42 wherein at least one encoded data 
block is a portion of a packet payload. 

Claim 50 (Previously Presented): The system of claim 42 wherein the decoder module decodes 
at least one encoded data block using a synchronization mechanism for verifying the 
identification of the one or more previously received data blocks from a corresponding encoder 
module. 

Claim 51 (Previously Presented): The system of claim 50 wherein the synchronization 
mechanism is an explicit synchronization mechanism. 

Claim 52 (Previously Presented): The system of claim 50 wherein the synchronization 
mechanism is an implicit synchronization mechanism. 

Claim 53 (Previously Presented): The system of claim 52 wherein the implicit synchronization 
mechanism is a reliable network transport protocol. 

Claim 54 (Previously Presented): The system of claim 50 wherein the synchronization 
mechanism i$ a reliable network transport protocol. 

Claim 55 (Previously Presented): The system of claim 42 wherein responsive to the data block 
being unencoded, the decoder module stores the contents of the respective received data block as 
a previously received data block further comprises determining whether to delete at least one of 
the previously received data blocks. 
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Claim 56 (Cancelled). 
Claim 57 (Cancelled). 

Claim 58 (Previously Presented): The system of claim 42 wherein the decoder module, 
responsive to no match in contents between the respective received data block and any one of the 
previously received data blocks, stores the respective received data block in the least recently 
used data structure, and associates the position of most recently used with the respective received 
data block. 

Claim 59 (Previously Presented): The system of claim 58 further comprising: responsive to the 
least recently used data structure being at the maximum capacity, storing the respective received 
data block in the least recently used data structure comprises replacing the previously received 
data block having the order position of least recently used data block with the respective received 
data block. 

Claim 60 (Previously Presented): A system for decoding one or more repetitive data blocks in 
data communicated over a network comprising: 

a decoder module receiving data blocks from an encoder module; 

a memory having a least recently used data structure for storing one or more previously 
received unique data blocks, each of the previously received unique data blocks 
having a unique identifier and a position from a most recently used to least recently 
used of the one or more previously received blocks; 

a synchronization mechanism including a same size for the least recently used data 
structure as the size of a second least recently used data structure accessible by the 
corresponding encoder module that transmitted the respective received data block, a 
reliable network transport protocol being used for the transmission of the respective 
received data block, 

wherein the decoder module determines whether the contents of each of the received data 
blocks is in encoded form, 
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wherein responsive to the respective data block being in encoded form, the decoder 
module selects the contents of a matching previously received block as the contents 
for the respective encoded block, and 

wherein responsive to the data block being unencoded, the decoder module stores the 
"\ contents of the respective received data block as a previously received data block. 

Claim 61 (Previously Presented): A system for decoding one or more repetitive data blocks in 
data communicated over a network comprising: 

a decoder module receiving data blocks from an encoder module; 

a memory having a least recently used data structure for storing one or more previously 
received unique data blocks, each of the previously received unique data blocks 
having a unique identifier and a position from a most recently used to least recently 
used of the one or more previously received blocks; 

a synchronisation mechanism including a same size for the least recently used data 
structure as the size of a second least recently used data structure accessible by the 
corresponding encoder module, an indicator for each received data block indicating 
whether the received data block has been previously associated with the second least 
recently used data structure, and an installation acknowledgement transmitting by the 
decoder module to the corresponding encoder module responsive to an installation of 
each received block in the least recently used data structure, 

wherein the decoder module determines whether the contents of each of the received data 
blocks is in encoded form, 

wherein responsive to the respective data block being in encoded form 9 the decoder 
module selects the contents of a matching previously received block as the contents 
for the respective encoded block, and 

wherein responsive to the data block being unencoded, the decoder module stores the 
contents of the respective received data block as a previously received data block. 
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Claim 62 (Previously Presented): A system for decoding one or more repetitive data blocks in 
data communicated over a network comprising: 

a decoder module receiving data blocks from an encoder module; 

a memory having a least recently used data structure for storing one or more previously 

received unique data blocks, each of the previously received unique data blocks 

having a unique identifier and a position from a most recently used to least recently 

used of the one or more previously received blocks; 
a synchronization mechanism wherein the decoder module receives a version number of 

the previously received data block having the matching contents, the version number 

indicating how many times the identifier for this data block has been re-used ? 
wherein the decoder module determines whether the contents of each of the received data 

blocks is in encoded form, 
wherein responsive to the respective data block being in encoded form, the decoder 

module selects the contents of a matching previously received block as the contents 

for the respective encoded block, and 
wherein responsive to the data block being unencoded, the decoder module stores the 

contents of the respective received data block as a previously received data block. 

Claim 63 (Previously Presented): The system of claim 42 wherein the system further comprises a 
decapsulation module for decapsulating a block of data received over the network from a source 
address supported by a corresponding encoder module. 

Claim 64 (Previously Presented): The system of claim 63 wherein the received data block is 
included in a packet, and the packet has been decapsulated as one packet. 

Claim 65 (Previously Presented): The system of claim 63 wherein the received data block is 
included in a packet and the packet has been decapsulated with, at least one other packet in an 
outgoing packet transmitted from a source address supported by a corresponding encoder 
module. 
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Claim 66 (Previously Presented): The system of claim 63 wherein the decapsulation module 
encapsulates the received block of data at a first layer of a model describing the flow of data 
across a network and the decoder module decodes the received block of data at a second layer of 
the model. 

Claim 67 (Previously Presented): The system of claim 66 wherein the first layer and the second 
layer are the same layer. 

Claim 68 (Previously Presented): The system of claim 66 wherein one of the layers is a 
connection-oriented layer and the other layer is a connectionless layer. 

Claim 69 (Currently Amended): A system for decoding one or more repetitive data blocks in 
data communicated over a network comprising: 

a decoder module that transmits to the encoder module over the network routing 

information in accordance with a routing protocol, the routing information including 
network topology information for the network for identifying one or more addresses 
of client devices that the decoder module supports to control selective encoding of 
data at the encoder module based on the client devices supported b v the decoder 
module by determining with the encoder module whether client devices are supported 
for decoding bv at least one corresponding decod er module based on destination 
addresses of the client devices and passing through the data when the destination 
addresses_of the client devices are not supported for decoding bv a decoder module, 
the decoder module receiving data blocks from an encoder module; and 

a memory accessible to the decoder module for storing the contents of one or more of the 
data blocks previously received From the encoder module, 

wherein the decoder module determines whether the contents of each of the received data 
blocks is in encoded form, 

wherein responsive to the respective data block being in encoded form, the decoder 
module selects the contents of a matching previously received block as the contents 
for the respective encoded block* and 
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wherein responsive to the data block being unencoded, the decoder module stores the 
contents of the respective received data block as a previously received data block. 

Claim 70 (Previously Presented): The system of claim 69 wherein the decoder module 
participates in one or more routing protocols for obtaining routing information. 

Claim 71 (Previously Presented): A system for decreasing one or more repetitive data blocks in 
data communicated over a network comprising: 

an encoder module, coupled in the network, the encoder module intercepting the data, the 
encoder module extracting data blocks from different communication sessions from 
the intercepted data, each extracted block having a destination address of a client 
device to which the extracted data block is destined, the encoder module determining 
whether the client device is supported for decoding by at least one corresponding 
decoder module based on the destination address of the client device, and the encoder 
module passing through the data when the destination address of the client device that 
is not supported for decoding by at least one decoder module; 

a first memory, accessible to the encoder module, for storing the contents of one or more 
data blocks previously transmitted by the encoder module, 

wherein the encoder module determines whether there is a match between the contents of 
each of the extracted data blocks and the contents of at least one previously 
transmitted data block, 

wherein responsive to a match, the encoder module encodes the respective extracted data 
block and transmits the respective extracted data block in encoded form to the at least 
one corresponding decoder module, and responsive to no match, the encoder module 
transmits the respective extracted data block in intercepted form to the at least one 
corresponding decoder module; 

the at least one corresponding decoder module being coupled in the network, the decoder 
module receiving data blocks for different communication sessions from the encoder 
module; and 
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a second memory accessible to the decoder module for storing the contents of one or 
more data blocks previously received from the encoder module, 

wherein the at least one corresponding decoder module determines whether the contents 
of each of the received data blocks is in encoded form, 

wherein responsive to the respective data block being in encoded form, the decoder 
module selects the contents of a matching previously received block as the contents 
for the respective encoded block, and responsive to the data block being unencoded, 
the decoder module stores the contents of the respective received data block as a 
previously received data block, and 

wherein the decoder module transmits routing information in accordance with a routing 
protocol, the routing information including network topology information for the 
network for identifying one or more addresses it supports over the network to the 
encoder module. 

Claim 72 (Previously Presented): A method for encoding one or more repetitive data blocks in 
data communicated over a network comprising: 

receiving routing information in accordance with a routing protocol over the network 

from one or more decoder modules, the routing information including network 

topology information for the network; 
determining, from the routing information, one or more destination addresses of client 

devices that is supported by each respective decoder module; 
intercepting data communicated from a server to a client device;; 
extracting data blocks from different communication sessions from the intercepted data, 

each extracted block having a destination addresses for the client device to which the 

intercepted data in destined; 
passing through the data when the destination address of the client device to which the 

intercepted data is destined is not one of the client devices supported for decoding by 

the one or more decoder modules; 
storing the contents of one or more data blocks previously transmitted; 

u 
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determining whether there is a match between the contents of each of the extracted data 
blocks and the contents of at least one previously transmitted data block; 

responsive to a match, encoding the respective extracted data block, and transmitting the 
respective extracted data block in encoded form to the at least one corresponding 
decoder module; and 

responsive to no match, the encoder module transmitting over the network the respective 
extracted data block in intercepted form. 

Claim 73 (Previously Presented): The method of claim 72 further comprising responsive to a 
match in contents, transmitting an indicator for identifying that the contents of a respective data 
block have been previously transmitted. 

Claim 74 (Previously Presented): The method of claim 72 further comprising synchronizing the 
identification of the one or more previously transmitted data blocks with at least one 
corresponding decoder module supporting the destination address of the extracted data block. 

Claim 75 (Previously Presented): The method of claim 72 further comprising, responsive to no 
match between the contents of the respective extracted data block and the contents of at least one 
of the previously transmitted blocks, determining whether to delete at least one of the previously 
transmitted data blocks in the memory, and storing the respective extracted data block in 
intercepted form in the memory. 

Claim 76 (Previously Presented): The method of claim 72 wherein storing the contents of one or 
more data blocks previously transmitted comprises storing one or more previously transmitted 
unique data blocks in a least recently used data structure, said lea$t recently used data structure 
having a maximum capacity and each of the previously transmitted unique data blocks having a 
unique identifier and a position in an order of most recently used to least recently used of the one 
or more stored blocks. 
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Claim 77 (Previously Presented): A method for encoding one or more repetitive data blocks in 
data communicated over a network comprising; 

intercepting data communicated from at least one server to at least one client device; 

extracting data blocks from different communication sessions from the intercepted data, 
each extracted block having a destination address of the client device to which the 
extracted data block is destined and determining, based on the destination address of 
the client device, whether the client device is supported for decoding by at least one 
corresponding decoder module; 

passing through the data when the destination address of the client device to which the 
intercepted data is destined is not supported for decoding by the at least one 
corresponding decoder module; 

storing one or more previously transmitted unique data blocks in a least recently used data 
structure, each of the previously transmitted unique data blocks having a unique 
identifier and a position in an order of most recently used to least recently used of the 
one or more stored blocks; 

determining whether there is a match between the contents of each of the extracted data 
blocks and the contents of at least one previously transmitted data block; 

responsive to a match in contents, encoding the respective extracted data block, 

transmitting the respective extracted data block in encoded form to the at least one 
corresponding decoder module, and associating the previously transmitted data block 
having the matching contents with the position in the least recently used data structure 
indicating the most recently used previously transmitted data block; and 

responsive to no match, transmitting over the network the respective extracted data block 
in intercepted form. 

Claim 78 (Previously Presented): The method of claim 76 further comprising, responsive to no 
match between the contents of an extracted data block and the contents of one of the previously 
transmitted data blocks, storing the extracted data block in the least recently used data structure, 
and associating the position of most recently used with the extracted data block. 
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Claim 79 (Previously Presented): The method of claim 78 further comprising: 

responsive to the least recently used data structure being at the maximum capacity, 
deleting the previously transmitted data block having the order position of least 
recently used data block. 

Claim 80 (Previously Presented): The method of claim 79 further comprising encoding at least 
one data block at a first layer of a model describing the flow of data across a network and the 
encapsulating the at least one extracted data block at a second layer of the model. 

Claim 81 (Previously Presented): The method of claim 80 wherein one of the layers is a 
connection-oriented layer and the other layer is a connectionless layer. 

Claim 82 (Cancelled). 

Claim 83 (Previously Presented): The method of claim 72 further comprising determining 
network topology information based upon the routing information from the one or more decoder 
modules* 

Claim 84 (Previously Presented): The method of claim 83 further comprising responsive to . 
multiple decoder modules in the network supporting the same address, determining a destination 
decoder module for one or more extracted data blocks based upon network topology information 
and routing criteria. 
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Claim 85 (Currently Amended): A method for decoding one or more repetitive data blocks in 

data communicated over a network comprising: 

transmitting routing information in accordance with a routing protocol for identifying one 
or more addresses of client devices that a decoder module supports over a network to 
an encoder modul e, to control selective encoding of data at the encoder module based 
on the client devices supported bv the decoder module by determining with the 
encoder module whether client devices are supported for decoding bv at least one 
corresponding decoder module based on destination addresses_of the client devices 
and passing through the data when the destination addresses of the client devices are 
not supported for decoding bv a decoder module , wherein the routing information 
includes network topology information for the network; 
receiving data blocks with the decoder module for different communication sessions from 
the encoder module; 

storing the contents of one or more data blocks previously received from the encoder 
module; 

determining whether the contents of each of the received data blocks is in encoded form; 
responsive to the respective data block being in encoded form, selecting the contents of a 

matching previously received block as the contents for the respective encoded block; 

and 

responsive to the data block being unencoded, storing the contents of the respective 
received data block as a previously received data block. 

Claim 86 (Previously Presented): The method of claim 85 further comprising receiving an 
indicator for identifying that the contents of at least one encoded data block have been previously 
transmitted to the decoder module. 

Claim 87 (Previously Presented): The method of claim 85 further comprising the identification 
of the one or more previously received data blocks from a corresponding encoder module. 
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Claim 88 (Previously Presented): The method of claim 85 further comprising responsive to the 
data block being unencoded, storing the contents of the respective received data block as a 
previously received data block further comprises determining whether to delete at least one of the 
previously received data blocks. 

Claim 89 (Previously Presented): The method of claim 85 wherein storing the previously 
received data blocks further comprises storing one or more previously received unique data 
blocks in a least recently used data structure, the least recently used data structure having a 
maximum capacity and each of the previously received unique data blocks having a unique 
identifier and a position in an order of most recently used to least recently used of the one or 
more previously received blocks. 

Claim 90 (Previously Presented): The method of claim 89 further comprising responsive to a 
match in contents, associates the previously received data block having the matching contents 
with the position in the least recently used data structure indicating the most recently used 
previously received data block. 

Claim 91 (Previously Presented): The method of claim 89 further comprising responsive to no 
match in contents between the respective received data block and any one of the previously 
received data blocks, storing the respective received data block in the least recently used data 
structure, and associating the position of most recently used with the respective received data 
block. 

Claim 92 (Previously Presented): The method of claim 91 further comprising: responsive to the 
least recently used data structure being at the maximum capacity, deleting the previously received 
data block having the order position of least recently used data block. 

Claim 93 (Previously Presented): The method of claim 85 further comprising decapsulating the 
received block of data at a first layer of a model describing the flow of data across a network and 
decoding the received block of data at a second layer of the modeL 
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Claim 94 (Previously Presented): The method of claim 93 wherein the fust layer and the second 
layer are the same layer. 

Claim 95 (Previously Presented): The method of claim 94 wherein one of the layers is a 
connection-oriented layer and the other layer is a connectionless layer. 

Claim 96 (Canceled). 
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